Eggplant DAI Model Execution Endpoints
Admin users can now generate API clients with a client_id and client_secret through the DAI UI.
Eggplant DAI uses the OAuth 2.0 authentication protocol with the client_credentials
grant type in order to enable access to REST API. This page explains how you can generate an API access key and secret, exchange those for a token, and use the token to call the remaining DAI REST API. For example, it can be used to call the Execution API which lets you run your models and interact with execution controls like Starting an Execution via REST. These services allow you to integrate this behavior into your DevOps toolchains.
Getting Started
The REST API is ready and available to use as soon as you finish installing Eggplant DAI. To gain access to the API, you need to:
- Find out where to send your credentials.
- Generate API client credentials via the user interface using the new experience. Requires DAI 6.2 or newer.
- Acquire an access token to authenticate with the DAI REST API.
As soon as you acquire an access token, you can start to test models with all the options that are available in the Eggplant DAI web app. After a run starts, you can leave it to process. An ID is returned which you can use to check the progress of a run. In addition, you can abort a run.
Generate Your API Client Credentials
Admin users can create API clients. The created clients have equivalent permissions to an admin user and can do almost everything an admin user can, except create more API clients.
To create an API client:
- Navigate to System > API Access
- Click Add New.
- Add a name and description for your credentials.
- Click Create.
- A prompt appears asking you to download a file. Click Download and store the credentials
.csv
file in a safe place.
You can now use the client_id
, client_secret
, and token_url
from your credentials file to Acquire an access token.
Treat these credentials as you would a password. Store them securely and do not share them. If API credentials are ever misplaced, leaked, or forgotten, they can be revoked or regenerated through the API Access interface.
Where to send credentials
If you have downloaded an API Client .csv
file or an exection environment .ini
, you can find the token_url
value in the files.
You can also construct the token_url
value to authenticate against by following these steps on any DAI instance:
- Navigate to the DAI login page.
- Copy the value from the address bar,
login_url
in following example. - Replace
/auth
and everything that follows it with/token
.
Example:
login_url=http://localhost:8000/auth/realms/eggplant/protocol/openid-connect/auth?client_id=...
token_url=http://localhost:8000/auth/realms/eggplant/protocol/openid-connect/token
The realm name is dynamic if you are an Eggplant Cloud customer. We will be denoting that with \{realm\}
for the remainder of the documentation and should be replaced with your custom value prior to usage.